<template>
  <div class="login-wrapper">
    <el-form ref="loginForm" :model="form" :rules="rules" class="login-form ele-bg-white" size="large"
             @keyup.enter.native="doSubmit">
      <h4>{{ $setting.name }}</h4>
      <el-form-item prop="username">
        <el-input placeholder="请输入登录账号" v-model="form.username" prefix-icon="el-icon-user" clearable/>
      </el-form-item>
      <el-form-item prop="password">
        <el-input placeholder="请输入登录密码" v-model="form.password" prefix-icon="el-icon-lock" show-password/>
      </el-form-item>
      <el-form-item prop="captcha">
        <div class="login-input-group">
          <el-input placeholder="请输入验证码" v-model="form.captcha" prefix-icon="el-icon-_vercode"/>
          <img v-if="captcha" :src="captcha" @click="changeCaptcha" class="login-captcha" alt=""/>
        </div>
      </el-form-item>
      <div class="el-form-item">
        <el-checkbox v-model="form.remember">记住密码</el-checkbox>
        <!-- <el-link @click="$router.push('/forget')" type="primary" class="ele-pull-right" :underline="false">忘记密码
        </el-link> -->
      </div>
      <div class="el-form-item">
        <el-button @click="doSubmit" :loading="loading" type="primary" class="login-btn" size="large">
          {{ loading ? '登录中' : '登录' }}
        </el-button>
      </div>
      <!-- <div class="ele-text-center" style="margin-bottom: 10px;">
        <i class="login-oauth-icon el-icon-_qq" style="background-color:#3492ed;"/>
        <i class="login-oauth-icon el-icon-_wechat" style="background-color:#4daf29;"/>
        <i class="login-oauth-icon el-icon-_weibo" style="background-color:#CF1900;"/>
      </div> -->
    </el-form>
    <div class="login-copyright">Copyright © 2017~2020 www.rxthink.cn. All rights reserved.</div>
  </div>
</template>

<script>
export default {
  name: "Login",
  data() {
    return {
      loading: false,  // 加载状态
      form: {username: 'admin888', password: '1234567890', captcha: '520', remember: true},  // 表单数据
      rules: {  // 表单验证规则
        username: [
          {required: true, message: '请输入账号', trigger: 'blur'}
        ],
        password: [
          {required: true, message: '请输入密码', trigger: 'blur'}
        ],
        captcha: [
          {required: true, message: '请输入验证码', trigger: 'blur'}
        ]
      },
      captcha: '',
      // key: ''
    }
  },
  mounted() {
    if (this.$store.state.user.token) this.$router.push(this.$route.query.from || '/');
    this.changeCaptcha();
  },
  methods: {
    /* 提交 */
    doSubmit() {
      this.$refs['loginForm'].validate((valid) => {
        if (!valid) return false;
        // if (this.form.captcha.toLowerCase() !== this.text) return this.$message.error('验证码错误');
        this.loading = true;
        let formData = new FormData();
        for (let key in this.form) formData.append(key, this.form[key]);
        this.$http.post('/login/login', this.form).then((res) => {
          this.loading = false;
          this.$message({type: 'success', message: '登录成功'});
          this.$store.dispatch('user/setToken', 'Bearer ' + res.data.access_token).then(() => {
            this.$router.push(this.$route.query.from || '/').catch(() => {});
          });
        });
      });
    },
    /* 更换图形验证码 */
    changeCaptcha() {
      this.$http.get('/login/captcha').then(res => {
        this.captcha = res.data.captcha;
        // this.form.captcha = this.text;
      }).catch(e => {
        this.$message.error(e.message);
      });
    }
  }
}
</script>

<style scoped>
.login-wrapper {
  padding: 50px 20px;
  position: relative;
  box-sizing: border-box;
  background-image: url("~@/assets/bg-login.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 100vh;
}

.login-wrapper:before {
  content: "";
  background-color: rgba(0, 0, 0, .2);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.login-form {
  margin: 0 auto;
  width: 360px;
  max-width: 100%;
  padding: 25px 30px;
  position: relative;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
  box-sizing: border-box;
  border-radius: 4px;
  z-index: 2;
}

.login-form h4 {
  text-align: center;
  margin: 0 0 25px 0;
}

.login-form > .el-form-item {
  margin-bottom: 25px;
}

.login-input-group {
  display: flex;
  align-items: center;
}

.login-input-group >>> .el-input {
  flex: 1;
}

.login-captcha {
  height: 38px;
  width: 102px;
  margin-left: 10px;
  border-radius: 4px;
  border: 1px solid #DCDFE6;
  text-align: center;
  cursor: pointer;
}

.login-captcha:hover {
  opacity: .75;
}

.login-btn {
  display: block;
  width: 100%;
}

.login-oauth-icon {
  color: #FFF;
  padding: 5px;
  margin: 0 10px;
  font-size: 18px;
  border-radius: 50%;
  cursor: pointer;
}

.login-copyright {
  color: #eee;
  padding-top: 20px;
  text-align: center;
  position: relative;
  z-index: 1;
}

@media screen and (min-height: 550px) {
  .login-form {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%);
    margin-top: -250px;
  }

  .login-copyright {
    position: absolute;
    bottom: 20px;
    right: 0;
    left: 0;
  }
}
</style>